| Nom i Cognoms:  |  |
|-----------------|--|
| TOTAL COSTICION |  |

1) Què tenim de mal fet en aquest codi de les rutines d'interrupció de les entrades externes 0 i 1 que compten els respectius polsos arribats?

ORG 0x08

ISR\_hi btfss INTCON,INT0IF

; check interrupt source retfie fast ; not caused by INT0, return

incf count0,F

bcf INTCON, INT0IF ;clear interrupt bit

retfie fast

ORG 0x18

ISR\_lo INTCON3,INT1IF ; check interrupt source btfss

retfie fast

; not caused by INT1, return incf count1,F

; output count to LEDs movff count,PORTD bcf INTCON3, INT1IF ;clear interrupt bit

retfie fast

2) Quan permetem dos nivells d'interrupció (RCON.IPEN=1) podem habilitar les de nivell baix sense habilitar les de nivell alt?

3) A banda de l'adreça de retorn, quins són els tres registres que representen el context d'un programa que cal salvar quan entra una rutina d'interrupció?

4) Si decidim preparar així l'arribada d'interrupcions externes INT0, on hi hem connectat un botó que ja hem comprovat que funcioni bé:

bsf RCON,IPEN ;Habilitem prioritats bsf INTCON,GIEH ;Habilitem les d'alta

bsf INTCON,GIEH ;Habilitem les d'alta prioritat bsf INTCON,INT0IE ;Habilitem la màscara de la interrupció INT0

...

Pot ser que ens salti la rutina d'interrupció instantàniament sense que ens dongui temps a tornar apretar el botó? Perquè?



Nom i Cognoms:\_\_\_\_

**5**) Si posem 4 displays de 7 segments a bits lliures dels ports A, B, C i D del nostre micro, podrem donar 10mA de corrent a tots els LEDS quan representem el número 8888? Perquè?

| Absolute Maximum Ratings <sup>(†)</sup>                               |                      |
|-----------------------------------------------------------------------|----------------------|
| Ambient temperature under bias                                        | 40°C to +85°C        |
| Storage temperature                                                   | 65°C to +150°C       |
| Voltage on any pin with respect to Vss (except VDD and MCLR) (Note 3) | 0.3V to (VDD + 0.3V) |
| Voltage on VDD with respect to Vss                                    | 0.3V to +7.5V        |
| Voltage on MCLR with respect to Vss (Note 2)                          | 0V to +13.25V        |
| Total power dissipation (Note 1)                                      | 1.0W                 |
| Maximum current out of Vss pin                                        | 300 mA               |
| Maximum current into Vod pin                                          | 250 mA               |
| Input clamp current, lik (Vi < 0 or Vi > VDD)                         |                      |
| Output clamp current, loκ (Vo < 0 or Vo > Vpp)                        | ±20 mA               |
| Maximum output current sunk by any I/O pin                            | 25 mA                |
| Maximum output current sourced by any I/O pin                         | 25 mA                |
| Maximum current sunk by all ports                                     | 200 mA               |
| Maximum current sourced by all ports                                  | 200 mA               |

**6**) Si a un bit del port A li entrem un senyal sinuidal centrat a 1.8V, amb amplitud de 1V i freqüència de 100Hz, quina probabilitat hi ha de llegir un '1' en un moment triat a l'atzar? I la de llegir un '0'? (suposeu VDD=4V) Justifica gràficament la resposta.

| DC CHA       | ARACTE | RISTICS                                                          | Standard Operating Conditions (unless otherwise stated) Operating temperature -40°C ≤ TA ≤ +85°C for industrial |          |       |                                       |  |  |
|--------------|--------|------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|----------|-------|---------------------------------------|--|--|
| Param<br>No. | Symbol | Characteristic                                                   | Min Max                                                                                                         |          | Units | Conditions                            |  |  |
|              | VIL    | Input Low Voltage                                                |                                                                                                                 |          |       |                                       |  |  |
|              |        | I/O Ports (except RC4/RC5 in<br>USB mode):                       |                                                                                                                 |          |       |                                       |  |  |
| D030         |        | with TTL Buffer                                                  | Vss                                                                                                             | 0.15 VDD | V     | VDD < 4.5V                            |  |  |
| D030A        |        |                                                                  | _                                                                                                               | 0.8      | V     | 4.5V ≤ VDD ≤ 5.5V                     |  |  |
| D031         |        | with Schmitt Trigger Buffer                                      | Vss                                                                                                             | 0.2 VDD  | V     |                                       |  |  |
|              |        | RB0 and RB1                                                      | Vss                                                                                                             | 0.3 VDD  | V     | When in I <sup>2</sup> C™ mode        |  |  |
| D032         |        | MCLR                                                             | Vss                                                                                                             | 0.2 VDD  | V     |                                       |  |  |
| D032A        |        | OSC1 and T1OSI                                                   | Vss                                                                                                             | 0.3 VDD  | V     | XT, HS,<br>HSPLL modes <sup>(1)</sup> |  |  |
| D033         |        | OSC1                                                             | Vss                                                                                                             | 0.2 VDD  | V     | EC mode <sup>(1)</sup>                |  |  |
|              | VIH    | Input High Voltage<br>I/O Ports (except RC4/RC5 in<br>USB mode): |                                                                                                                 |          |       |                                       |  |  |
| D040         |        | with TTL Buffer                                                  | 0.25 VDD + 0.8V                                                                                                 | VDD      | V     | VDD < 4.5V                            |  |  |
| D040A        |        |                                                                  | 2.0                                                                                                             | VDD      | V     | 4.5V ≤ VDD ≤ 5.5V                     |  |  |
| D041         |        | with Schmitt Trigger Buffer                                      | 0.8 VDD                                                                                                         | VDD      | ٧     | _                                     |  |  |
|              |        | RB0 and RB1                                                      | 0.7 VDD                                                                                                         | VDD      | V     | When in I <sup>2</sup> C mode         |  |  |
| D042         |        | MCLR                                                             | 0.8 VDD                                                                                                         | VDD      | V     |                                       |  |  |
| D042A        |        | OSC1 and T1OSI                                                   | 0.7 VDD                                                                                                         | VDD      | V     | XT, HS,<br>HSPLL modes <sup>(1)</sup> |  |  |
| D043         |        | OSC1                                                             | 0.8 VDD                                                                                                         | VDD      | V     | EC mode <sup>(1)</sup>                |  |  |

| 7) | Tindrà | el | mateix | efecte | executar | aquests | dos | codis? |
|----|--------|----|--------|--------|----------|---------|-----|--------|
|----|--------|----|--------|--------|----------|---------|-----|--------|

TRISA = 0xFE; LATA=0x01; PORTA=0xFF; TRISA=0x00;

**8**) En la pantalla LCD emprada a la pràctica, i amb les connecxions realitzades, com podem escriure el contingut de la memòria de generació de caràcters, CGRAM? i com podem llegir-la?

Table 7.6 HD44780 instruction set

| Instruction                              | Code |     |    |      |     |     |     |     |      |    | D                                                                                                                                                            | Execution          |
|------------------------------------------|------|-----|----|------|-----|-----|-----|-----|------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| Instruction                              | RS   | R/W | В7 | B6 ] | 35  | В4  | B3  | B2  | B1   | В0 | Description                                                                                                                                                  | time               |
| Clear display                            | 0    | 0   | 0  | 0    | 0   | 0   | 0   | 0   | 0    | 1  | Clears display and returns cursor to the home position (address 0).                                                                                          | 1.64 ms            |
| Cursor home                              | 0    | 0   | 0  | 0    | 0   | 0   | 0   | 0   | 1    | *  | Returns cursor to home position (address 0). Also returns display being shifted to the original position. DDRAM contents remain unchanged.                   | 1.64 ms            |
| Entry mode set                           | 0    | 0   | 0  | 0    | 0   | 0   | 0   | 1   | I/D  | S  | Set cursor move direction (I/D), specifies to shift the display (S). These operations are performed during data read/write.                                  | 40 μs              |
| Display on/off<br>control                | 0    | 0   | 0  |      | 0   | 0   | 1   |     | С    | В  | Sets on/off of all display (D), cursor on/off (C) and blink of cursor position character (B).                                                                | 40 μs              |
| Cursor /display<br>shift                 | 0    | 0   | 0  | 0    | 0   | 1   | S/C | R/I | *    | *  | Sets cursor-move or display-(S/C), shift direction (R/L). DDRAM contents remains unchanged.                                                                  | 40 μs              |
| Function set                             | 0    | 0   | 0  | 0    | 1   | DL  | N   | F   | *    | *  | Sets interface data length (DL), number of display line (N) and character font (F).                                                                          | 40 μs              |
| Set CGRAM<br>address                     | 0    | 0   | 0  |      |     |     |     |     | dre  |    | Sets the CGRAM address. CGRAM data is sent and received after this setting.                                                                                  | 40 μs              |
| Set DDRAM<br>address                     | 0    | 0   | 1  | _    |     |     |     |     | ress |    | Sets the DDRAM address. DDRAM data is sent and received after this setting.                                                                                  | $40\mu \mathrm{s}$ |
| Read busy flag<br>and address<br>counter | 0    | 1   | BF | ado  | dre | ss  | ,   |     | AV.  | I  | Reads busy flag (BF) indicating internal operation is being performed and reads CGRAM or DDRAM address counter contents (depending on previous instruction). | 0 μs               |
| Write to CGRAM<br>or DDRAM               | 1    | 0   |    |      | wr  | ite | dat | a   |      |    | Writes data to CGRAM or DDRAM.                                                                                                                               | 40 μs              |
| Read from<br>CGRAM or<br>DDRAM           | 1    | 1   |    |      | rea | ad  | dat | a   |      |    | Reads data from CGRAM or DDRAM.                                                                                                                              | 40 μs              |